# NCS 362: Embedded Systems

Instructor: Dr. Ahmed Shalaby <u>http://bu.edu.eg/staff/ahmedshalaby14#</u>

# How? Course Book

#### Embedded Systems - Shape The World

http://users.ece.utexas.edu/~valvano/Volume1/E-Book/

C 🛈 users.ece.utexas.edu/~valvano/Volume1/E-Book/

#### Embedded Systems - Shape The World



Jonathan Valvano and Ramesh Yerraballi

#### **Embedded Software in C**

http://users.ece.utexas.edu/~valvano/embed/toc1.htm

Table of Contents

- Chapter 1: Introduction
- Chapter 2: <u>Fundamental Concepts</u>
- Chapter 3: <u>Electronics</u>
- Chapter 4: <u>Digital Logic</u>
- Chapter 5: <u>Introduction to C</u>
- Chapter 6: <u>Microcontroller Ports</u>
- Chapter 7: <u>Design and Development Process</u>
- Chapter 8: Switches and LEDs
- Chapter 9: <u>Arrays and Functional Debugging</u>
- Chapter 10: <u>Finite State Machines</u>
- Chapter 11: <u>UART The Serial Interface</u>
- Chapter 12: <u>Interrupts</u>
- Chapter 13: DAC and Sound
- Chapter 14: ADC and Data Acquisition
- Chapter 15: Systems Approach to Game Design
- Chapter 16: <u>The Internet of Things</u>
- Appendix: <u>Reference Material</u>
- Video links: Web links to videos (All chapters 1 to 16)
- Closed caption files: <u>Closed caption srt files</u>
- Index: Index of terms and concepts

# How? Course Book

the avr microcontroller and embedded systems using assembly and c



#### Introduction to Computing Chapter 0

The AVR microcontroller and embedded systems using assembly and c



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi

# Topics

- Internal organization of computers
  - The different parts of a computer
    - I/O
    - Memory
    - CPU
  - Connecting the different parts
    - Connecting memory to CPU
    - Connecting I/Os to CPU
  - How computers work

# Internal organization of computers

- CPU
- Memory
- I/O
  - Input
    - E.g. Keyboard, Mouse, Sensor
  - Output
    - E.g. LCD, printer, hands of a robot

# Memory

- Everything that can store, retain, and recall information.
  - E.g. hard disk, a piece of paper, etc.

# Memory characteristics

- Capacity
  - The number of bits that a memory can store.
    - E.g. 128 Kbits, 256 Mbits
- Organization
  - How the locations are organized
    - E.g. a 128 x 4 memory has 128 locations, 4 bits each
- Access time
  - How long it takes to get data from memory



# **Semiconductor memories**

- ROM
  - Mask ROM
  - PROM (Programmable ROM)
  - EPROM (Erasable PROM)
  - EEPROM (Electronic Erasable PROM)
  - Flash EPROM

- RAM
  - SRAM (Static RAM)
  - DRAM (Dynamic RAM)
  - NV-RAM (Nonvolatile RAM)

### Memory\ROM\Mask ROM

• Programmed by the IC manufacturer

# Memory\ROM\PROM (Programmable ROM)

- OTP (One-Time Programmable)
  - You can program it only once

#### Memory\ROM\EPROM (Erasable Programmable ROM)

- UV-EPROM
  - You can shine ultraviolet (UV) radiation to erase it
  - Erasing takes up to 20 minutes
  - The entire contents of ROM are erased



| Table 0-5: Some UV-EPROM Chips |          |               |        |      |                 |                     | 28 🗆 Vcc<br>27 🗖 PGN |
|--------------------------------|----------|---------------|--------|------|-----------------|---------------------|----------------------|
| Part #                         | Capacity | Org.          | Access | Pins | V <sub>PP</sub> |                     | 2764 26 N.C.         |
| 2716                           | 16K      | $2K \times 8$ | 450 ns | 24   | 25 V            | A6 🗆 4<br>A5 🗖 5    | 25 🗖 A8<br>24 🗖 A9   |
| 2732                           | 32K      | $4K \times 8$ | 450 ns | 24   | 25 V            |                     | 23 🗖 A11             |
| 2732A-20                       | 32K      | $4K \times 8$ | 200 ns | 24   | 21 V            | A3 Ц 7<br>A2 Ц 8    | 22 🖵 OE<br>21 🗖 A10  |
| 27C32-1                        | 32K      | $4K \times 8$ | 450 ns | 24   | 12.5 V CMOS     | A1 🗖 9              | 20 🗖 CE              |
| 2764-20                        | 64K      | $8K \times 8$ | 200 ns | 28   | 21 V            |                     | 19 🗖 07<br>18 🗖 06   |
| 2764A-20                       | 64K      | $8K \times 8$ | 200 ns | 28   | 12.5 V          | 01 🗖 12             | 17 🗖 05              |
| 27C64-12                       | 64K      | $8K \times 8$ | 120 ns | 28   | 12.5 V CMOS     | 02 🗖 13<br>GND 🗖 14 | 16 □ O4<br>15 □ O3   |

AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi

#### Memory\ROM\EEPROM (Electrically Erasable Programmable ROM)



| Part No.  | Capacity | Org.                  | Speed  | Pins | V <sub>PP</sub> |
|-----------|----------|-----------------------|--------|------|-----------------|
| 2816A-25  | 16K      | $2K \times 8$         | 250 ns | 24   | 5 V             |
| 2864A     | 64K      | $8 \text{K} \times 8$ | 250 ns | 28   | 5 V             |
| 28C64A-25 | 64K      | $8K \times 8$         | 250 ns | 28   | 5 V CMOS        |
| 28C256-15 | 256K     | $32K \times 8$        | 150 ns | 28   | 5 V             |
| 28C256-25 | 256K     | $32K \times 8$        | 250 ns | 28   | 5 V CMOS        |

AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi

#### Memory\ROM\Flash ROM

- Erased in a Flash
- the entire device is erased at once

| Part No.  | Capacity | Org.            | Speed  | Pins | V <sub>PP</sub> |
|-----------|----------|-----------------|--------|------|-----------------|
|           |          |                 |        |      |                 |
| 28F256-20 | 256K     | $32K \times 8$  | 200 ns | 32   | 12 V CMOS       |
| 28F010-15 | 1024K    | $128K \times 8$ | 150 ns | 32   | 12 V CMOS       |
| 28F020-15 | 2048K    | $256K \times 8$ | 150 ns | 32   | 12 V CMOS       |

AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi

# **Semiconductor memories**

- ROM
  - Mask ROM
  - PROM (Programmable ROM)
  - EPROM (Erasable PROM)
  - EEPROM (Electronic Erasable PROM)
  - Flash EPROM

- RAM
  - SRAM (Static RAM)
  - DRAM (Dynamic RAM)
  - NV-RAM (Nonvolatile RAM)

# Memory\RAM\SRAM (Static RAM)

- Made of flip-flops (Transistors)
- Advantages:
  - Faster
  - No need for refreshing
- Disadvantages:
  - High power consumption
  - Expensive

|       |    | $\overline{}$ | 厂  |    | 1 |       |
|-------|----|---------------|----|----|---|-------|
| A7    | 1  |               |    | 24 | Þ | Vcc   |
| A6    | 2  |               |    | 23 | Þ | A8    |
| A5    | 3  |               |    | 22 | Þ | A9    |
| A4    | 4  | 2K x          | 8  | 21 | Þ | WE    |
| A3    | 5  | SBVI          | Л  | 20 | Þ | OE    |
| A2    | 6  |               | VI | 19 | Þ | A10   |
| A1    | 7  |               |    | 18 | Þ | CS    |
| A0    | 8  |               |    | 17 | Þ | I/O 8 |
| I/O 1 | 9  |               |    | 16 | 口 | I/O 7 |
| I/O 2 | 10 |               |    | 15 | Þ | I/O 6 |
| 1/0 3 | 11 |               |    | 14 | Þ | I/O 5 |
| GND   | 12 |               |    | 13 | þ | I/O 4 |

# Memory\RAM\DRAM (Dynamic RAM)

- Made of capacitors
- Advantages:
  - Less power consumption
  - Cheaper
  - High capacity
- Disadvantages:
  - Slower
  - Refresh needed

# Memory\RAM\NV-RAM (Nonvolatile RAM)

- Made of SRAM, Battery, control circuitry
- Advantages:
  - Very fast
  - Infinite program/erase cycle
  - Non-volatile
- Disadvantage:
  - Expensive

#### Internal parts of computers\CPU

- Tasks:
  - It should execute instructions
    - It should recall the instructions one after another and execute them

# Connecting memory to CPU

• Memory pin out



# Connecting memory to CPU





AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi

#### **Reading from memory**





AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi

# Connecting I/Os to CPU

• CPU should have lots of pins!



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi

# Connecting I/Os to CPU using bus



# Connecting I/Os and Memory to CPU



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi

# Connecting I/Os and Memory to CPU using bus (Peripheral I/O)



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi





AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi
#### Connecting I/Os and Memory to CPU using bus (Memory Mapped I/O)



#### Connecting I/Os and Memory to CPU using bus (Memory Mapped I/O)



#### Connecting I/Os and Memory to CPU using bus (Memory Mapped I/O)



© 2011 Pearson Higher Education, Upper Saddle River, NJ 07458. • All Rights Reserved.

 Design an address decoder for address of 300H to 3FFH.

 Design an address decoder for address of 300H to 3FFH.

Solution

1. Write the address range in binary

 Design an address decoder for address of 300H to 3FFH.

Solution

- 1. Write the address range in binary
- 2. Separate the fixed part of address

From address 300H → To address 3FFH →

 $\begin{array}{c} a11 a10 a9 a8 \\ 0 & 0 & 1 & 1 \\ 0 & 0 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\ \end{array}$ 

 Design an address decoder for address of 300H to 3FFH.

Solution

- 1. Write the address range in binary
- 2. Separate the fixed part of address

From address 300H → To address 3FFH →

 $\begin{array}{c} a11 a10 a9 a8 \\ 0 & 0 & 1 & 1 \\ 0 & 0 & 0 & 1 & 1 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\ \end{array}$ 

 Design an address decoder for address of 300H to 3FFH.

Solution

- 1. Write the address range in binary
- 2. Separate the fixed part of address
- 3. Design the logic circuit.

From address 300H → To address 3FFH →

 $\begin{array}{c} a11 a10 a9 a8 \\ \hline 0 0 1 1 \\ \hline 0 0 1 1 \\ \hline 1 1 1 1 1 1 1 1 \\ \hline 1 1 1 1 \\ \hline \end{array}$ 

 Design an address decoder for address of 300H to 3FFH.



 Design an address decoder for address of 300H to 3FFH.



 Design an address decoder for address of 300H to 3FFH.



### Inside the CPU

- PC (Program Counter)
- Instruction decoder
- ALU (Arithmetic Logic Unit)
- Registers



### How computers work



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi © 2011 Pearson Higher Education, Upper Saddle River, NJ 07458. • All Rights Reserved.

Ð

### How Instruction decoder works



# Von Neumann vs. Harvard architecture



• Von Neumann architecture



A von Neumann architecture has only one bus which is used for both data transfers and instruction fetches, and therefore data transfers and instruction fetches must be scheduled

# NCS 362: Embedded Systems

Instructor: Dr. Ahmed Shalaby <u>http://bu.edu.eg/staff/ahmedshalaby14#</u>

#### Introduction to AVR Chapter 1

The AVR microcontroller and embedded systems using assembly and c



# Topics

- Microcontrollers vs. Microprocessors
- Most common microcontrollers
- AVR Features
- AVR members

### General Purpose Microprocessors vs. Microcontrollers

General Purpose Microprocessors



• Microcontrollers



### Most common microcontrollers

- 8-bit microcontrollers
  - -AVR
  - PIC
  - HCS12
  - 8051
- 32-bit microcontrollers
  - ARM
  - PIC32

### AVR internal architecture



### AVR internal architecture



- Classic AVR
  - e.g. AT90S2313, AT90S4433
- Mega
  - e.g. ATmega8, ATmega32, ATmega128
- Tiny
  - e.g. ATtiny13, ATtiny25
- Special Purpose AVR
  - e.g. AT90PWM216,AT90USB1287

Classic AVR

#### - e.g. AT90S2313, AT90S4433

| •                                                                                                                                                                                                                                                       | Mega      | Table 1-3: Some Members of the Classic Family |             |             |                |                  |                      |        |                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------------------------------------|-------------|-------------|----------------|------------------|----------------------|--------|--------------------------|
|                                                                                                                                                                                                                                                         | – e.g     | Part Num                                      | Code<br>ROM | Data<br>RAM | Data<br>EEPROM | I/O pins<br>pins | ADC                  | Timers | Pin numbers<br>& Package |
|                                                                                                                                                                                                                                                         | <b></b> ! | AT90S2313                                     | 2K          | 128         | 128            | 15               | 0                    | 2      | SOIC20,PDIP20            |
| •                                                                                                                                                                                                                                                       | IINV      | AT90S2323                                     | 2K          | 128         | 128            | 3                | 0                    | 1      | SOIC8,PDIP8              |
|                                                                                                                                                                                                                                                         | <b>J</b>  | AT90S4433                                     | 4K          | 128         | 256            | 20               | 6                    | 2 :    | IQFP32,PDIP28            |
| <ul> <li>BODG</li> <li>Notes:         <ol> <li>All ROM, RAM, and EEPROM memories are in bytes.</li> <li>Data RAM (General-Purpose RAM) is the amount of RAM available for data manip<br/>and) in addition to the Begistern space</li> </ol> </li> </ul> |           |                                               |             |             |                |                  | anipulation (scratch |        |                          |
| -                                                                                                                                                                                                                                                       | oped      | pad) in addition to the Registers space.      |             |             |                |                  |                      |        |                          |

-e.g. AT90PWWZT6, AT900SBT287

Classic AVR

 – e.g. AT90S2313, AT90S4433

| • | Mega  | Table 1-3: Some Members of the Classic Family                                                                                                                                                                                                                                                                                                                                                     |             |             |                |                  |     |        |                                |
|---|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|----------------|------------------|-----|--------|--------------------------------|
|   | – e.g | Part Num                                                                                                                                                                                                                                                                                                                                                                                          | Code<br>ROM | Data<br>RAM | Data<br>EEPROM | I/O pins<br>pins | ADC | Timers | Pin numbers<br>& Package       |
| • | Tiny  | Table 1-4: Some Members of the Mega Family                                                                                                                                                                                                                                                                                                                                                        |             |             |                |                  |     |        |                                |
|   | – e.d | Part Num                                                                                                                                                                                                                                                                                                                                                                                          | Code<br>ROM | Data<br>RAM | Data<br>EEPROM | I/O pins<br>pins | ADC | Timers | Pin numbers<br>& Package       |
|   |       | ATmega8                                                                                                                                                                                                                                                                                                                                                                                           | 8K          | 1K          | 0.5K           | 23               | 8   | 3      | TQFP32,PDIP28                  |
| • | Sped  | Almegal6<br>ATmega32                                                                                                                                                                                                                                                                                                                                                                              | 16K<br>32K  | 2K          | 0.5K<br>1K     | <u> </u>         | 8   | 3      | TQFP44,PDIP40<br>TQFP44,PDIP40 |
|   | -     | ATmega64                                                                                                                                                                                                                                                                                                                                                                                          | 64K         | 4K          | 2K             | 54               | 8   | 4      | TQFP64,MLF64                   |
|   | – e.( | ATmega1280       128K       8K       4K       86       16       6       TQFP100,CBGA         Notes:       1.       All ROM, RAM, and EEPROM memories are in bytes.       2.       Data RAM (General-Purpose RAM) is the amount of RAM available for data manipulation (scratch pad) in addition to the Registers space.         3.       All the above chips have USART for serial data transfer. |             |             |                |                  |     |        |                                |

Classic AVR

 – e.g. AT90S2313, AT90S4433



### Let's get familiar with the AVR part numbers



### Introduction to Assembly Chapter 2

The AVR microcontroller and embedded systems using assembly and c



### Topics

- AVR's CPU
  - Its architecture
  - Some simple programs
- Data Memory access
- Program memory
- RISC architecture



### AVR's CPU

- AVR's CPU
  - ALU
  - 32 General Purpose registers (R0 to R31)
  - PC register
  - Instruction decoder



#### Some simple instructions 1. Loading values into the general purpose registers

#### LDI (Load Immediate)

- LDI Rd, k
  - Its equivalent in high level languages:
     Rd = k
- Example:
  - LDI R16,53
    - R16 = 53
  - LDI R19,132
  - LDI R23,0x27
    - R23 = 0x27



#### Some simple instructions 2. Arithmetic calculation

- There are some instructions for doing Arithmetic and logic operations; such as: ADD, SUB, MUL, AND, etc.
- ADD Rd,Rs
  - Rd = Rd + Rs
  - Example:
  - ADD R25, R9
    - R25 = R25 + R9
  - ADD R17,R30
    - R17 = R17 + R30



© 2011 Pearson Higher Education, Upper Saddle River, NJ 07458. • All Rights Reserved.

• Write a program that calculates 19 + 95



© 2011 Pearson Higher Education, Upper Saddle River, NJ 07458. • All Rights Reserved.

• Write a program that calculates 19 + 95

| LDI R16, | 19  | ;R16 = 19        |
|----------|-----|------------------|
| LDI R20, | 95  | ;R20 = 95        |
| ADD R16, | R20 | ;R16 = R16 + R20 |



• Write a program that calculates 19 + 95 + 5

• Write a program that calculates 19 + 95 + 5

| LDI | R16, 19  | ;R16 = 19        |
|-----|----------|------------------|
| LDI | R20, 95  | ;R20 = 95        |
| LDI | R21, 5   | ;R21 = 5         |
| ADD | R16, R20 | ;R16 = R16 + R20 |
| ADD | R16, R21 | ;R16 = R16 + R21 |
# A simple program

• Write a program that calculates 19 + 95 + 5

| LDI | R16, 19  | ;R16 = 19        |
|-----|----------|------------------|
| LDI | R20, 95  | ;R20 = 95        |
| LDI | R21, 5   | ;R21 = 5         |
| ADD | R16, R20 | ;R16 = R16 + R20 |
| ADD | R16, R21 | ;R16 = R16 + R21 |

| LDI | R16, 19  | ;R16 = 19        |
|-----|----------|------------------|
| LDI | R20, 95  | ;R20 = 95        |
| ADD | R16, R20 | ;R16 = R16 + R20 |
| LDI | R20, 5   | ;R20 = 5         |
| ADD | R16, R20 | ;R16 = R16 + R20 |

### Some simple instructions

### 2. Arithmetic calculation

- SUB Rd,Rs
  - Rd = Rd Rs
- Example:
  - SUB R25, R9
    - R25 = R25 R9
  - SUB R17,R30
    - R17 = R17 R30



© 2011 Pearson Higher Education, Upper Saddle River, NJ 07458. • All Rights Reserved.

### Some simple instructions

### 2. Arithmetic calculation

- INC Rd
  - Rd = Rd + 1
- Example:
  - INC R25
    - R25 = R25 + 1
- DEC Rd
  - Rd = Rd 1
- Example:
  - DEC R23
    - R23 = R23 1







AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi









|               |              |         | 1  |            |              |             | •              | <u> </u>     |                      |         |                                       |
|---------------|--------------|---------|----|------------|--------------|-------------|----------------|--------------|----------------------|---------|---------------------------------------|
| Add           | ress         | Name    |    | Add        | ress         | Name        |                | Add          | ress                 | Name    | BOACE                                 |
| 1/0           | Mem.         |         |    | 1/O        | Mem.         | DIND        | -              |              | Mem.                 | 0004411 |                                       |
| \$00<br>¢01   | \$20<br>¢21  |         |    | φ10<br>¢17 | \$30<br>\$37 |             | -              | \$2D         | \$4D                 |         |                                       |
| \$01          | ⇒∠ I<br>¢22  | TWOR    |    | \$18       | \$38         | PORTB       | -              | \$20         | \$40<br>\$40         |         |                                       |
| \$02<br>¢02   | \$22<br>\$22 |         |    | \$1Q       | \$30         |             | -              | \$2D<br>\$2E | \$4D                 |         |                                       |
| \$03          | ⊕23<br>©24   |         |    | \$1A       | \$3A         |             | -              | ⇒∠⊏<br>¢2⊑   | - ⊅4⊏<br>©1⊏         | TCCR1A  |                                       |
| \$04          | φ24<br>¢25   | ADCH    |    | \$1B       | \$3B         | PORTA       | -              | \$2F         | \$4F<br>\$50         | SEIOR   |                                       |
| \$05          | \$26         |         |    | \$1C       | \$3C         | FECR        | 1              | φ30          | φ50                  |         |                                       |
| \$07          | \$20<br>\$27 |         |    | \$1D       | \$3D         | FEDR        | -              | \$31         | \$51                 | OCDR    | RAM EEPROM Timers                     |
| \$08          | \$28         | ACSR    |    | \$1F       | \$3F         | FFARI       | 1              | ¢20          | ¢50                  | USCUAL  |                                       |
| \$09          | \$29         | LIBRRI  |    | \$1F       | \$3F         | EEARH       |                | \$3Z         | \$0Z                 | TCNTU   |                                       |
| \$0A          | \$2A         | UCSRB   |    | •          |              |             | -              | \$33<br>¢24  | \$00<br>0E4          | MOLICER |                                       |
| \$0B          | \$2B         | UCSRA   |    | \$20       | \$40         |             | -              | \$34<br>\$25 | \$04<br>\$55         | MCUCSR  |                                       |
| \$0C          | \$2C         | UDR     |    | \$21       | \$41         | WDTCR       | -              | \$35<br>\$36 | \$55<br>\$56         | TWCP    |                                       |
| \$0D          | \$2D         | SPCR    |    | \$22       | \$42         | ASSR        | -              | \$30<br>\$27 | \$30<br>\$57         | SPMCP   |                                       |
| \$0E          | \$2E         | SPSR    |    | \$23       | \$43         | OCB2        |                | \$38<br>\$38 | \$58                 |         | data bus                              |
| \$0F          | \$2F         | SPDR    |    | \$24       | \$44         | TCNT2       | 1              | \$30<br>\$30 | \$50<br>\$50         | TIMSK   | to A                                  |
| \$10          | \$30         | PIND    |    | \$25       | \$45         | TCCR2       | 1              | \$39<br>\$3A | φ <u></u> 59<br>\$5Δ | CIER    |                                       |
| \$11          | \$31         | DDRD    |    | \$26       | \$46         | ICR1        | -              | \$3R         | \$5R                 | GICR    | IS                                    |
| \$12          | \$32         | PORTD   |    | \$27       | \$47         | ICR1H       | 1              | \$3C         | \$50                 | OCR0    |                                       |
| \$13          | \$33         | PINC    |    | \$28       | \$48         | OCR1BI      | -              | \$3D         | \$5D                 | SPI     |                                       |
| \$14          | \$34         | DDRC    |    | \$29       | \$49         | OCR1BH      |                | \$3E         | \$5E                 | SPH     | Interrupt Other                       |
| \$15          | \$35         | PORTC   |    | \$2A       | \$4A         | OCR1AI      | 1              | \$3F         | \$5F                 | SREG    | Unit Ports Perinherals                |
|               |              | ·       | I  | ψ27 (      | ψint         | 0 OIT III L |                |              | φο <u>μ</u>          | ONLO    |                                       |
|               | Regi         | sters   | -1 |            |              |             |                |              |                      |         |                                       |
| \$001F        |              |         |    | Eva        | mnl          | . Ada       |                | aton         | to of                | Flagat  | ion 0x00 to contents of location 0x05 |
| \$0020        |              |         |    | Exa        | mpie         | e: Add      |                | nen          | is of                | IOCal   |                                       |
|               | Standa       | ard I/O |    | and        | stor         | ro tho      | rasi           | ılt in       | n Inc                | ation   | Nx 313                                |
| :             | Pogi         | stors   |    | unu        | 5101         | c inc       | 1030           |              | 100                  |         | 0,010.                                |
|               | ixegi        | 51615   |    |            |              |             |                |              |                      |         |                                       |
| \$005F        |              |         |    | 5          | solui        | tion:       |                |              |                      |         |                                       |
| \$0060        |              |         | _  |            |              |             |                |              |                      |         |                                       |
|               | Ger          | eral    |    |            | т            | ם פת        | 20             | 0.29         | 0                    |         | $\cdot R20 = [0x90]$                  |
| :             | purp         | ose     |    |            | -            |             | 20,            | UAJ          | U                    |         | /120 - [0890]                         |
|               | R/           | M       |    |            | -            |             | 01             | <u> </u>     | -                    |         | 501 [0.05]                            |
|               | (SR          |         |    |            | T            | DS R        | R2Ι,           | 0x9          | 5                    |         | ;R21 = [0x95]                         |
|               |              | ,)      |    |            |              |             |                |              |                      |         |                                       |
|               |              |         |    |            | F            | ADD R       | 20,            | R21          |                      |         | ;R20 = R20 + R21                      |
|               |              | · - ·   |    |            |              |             |                |              |                      |         |                                       |
|               |              |         |    |            | ç            | STS 0       | $\mathbf{x31}$ | 3. R         | 20                   |         | :[0x313] = R20                        |
|               |              | I       |    |            |              |             | 1.0 1.         | - / - \      |                      |         |                                       |
| <b>\$FFFF</b> | 1            | 1       |    |            |              |             |                |              |                      |         |                                       |



| ſ | Add    | ress   | Nome    |              | Add                                          | ress | Neme       | 1     | Add         | ress  | Neme    |     | <b>R</b> r | nacc    |           |              |      |
|---|--------|--------|---------|--------------|----------------------------------------------|------|------------|-------|-------------|-------|---------|-----|------------|---------|-----------|--------------|------|
| H | I/O    | Mem.   | Name    |              | I/O                                          | Mem. | Name       |       | 1/0         | Mem.  | Name    |     | ノト         | Jaur    | J         |              |      |
|   | \$00   | \$20   | TWBR    |              | \$16                                         | \$36 | PINB       |       | \$2B        | \$4B  | OCR1AH  |     |            |         |           |              |      |
|   | \$01   | \$21   | TWSR    |              | \$17                                         | \$37 | DDRB       |       | \$2C        | \$4C  | TCNT1L  |     |            |         |           |              |      |
|   | \$02   | \$22   | TWAR    |              | \$18                                         | \$38 | PORTB      |       | \$2D        | \$4D  | TCNT1H  |     |            |         |           |              |      |
|   | \$03   | \$23   | TWDR    |              | \$19                                         | \$39 | PINA       |       | \$2E        | \$4E  | TCCR1B  |     | ſ          |         |           | ] [          |      |
|   | \$04   | \$24   | ADCL    |              | \$1A                                         | \$3A | DDRA       |       | \$2F        | \$4F  | TCCR1A  |     |            |         |           |              |      |
|   | \$05   | \$25   | ADCH    |              | \$1B                                         | \$3B | PORTA      |       | \$30        | \$50  | SFIOR   |     |            |         |           |              |      |
|   | \$06   | \$26   | ADCSRA  |              | \$1C                                         | \$3C | EECR       |       | <b>0</b> 04 | 0.54  | OCDR    |     |            |         |           | Timore       |      |
|   | \$07   | \$27   | ADMUX   |              | \$1D                                         | \$3D | EEDR       |       | \$31        | \$51  | OSCCAL  |     |            | 1.7411  |           |              |      |
|   | \$08   | \$28   | ACSR    |              | \$1E                                         | \$3E | EEARL      |       | \$32        | \$52  | TCNT0   |     |            |         |           |              |      |
|   | \$09   | \$29   | UBRRL   |              | \$1F                                         | \$3F | EEARH      |       | \$33        | \$53  | TCCR0   |     | s          |         |           |              |      |
|   | \$0A   | \$2A   | UCSRB   |              | ¢20                                          | ¢40  | UBRRC      |       | \$34        | \$54  | MCUCSR  |     |            |         |           |              |      |
|   | \$0B   | \$2B   | UCSRA   |              | φ20                                          | φ40  | UBRRH      |       | \$35        | \$55  | MCUCR   |     | T          |         |           |              |      |
|   | \$0C   | \$2C   | UDR     |              | \$21                                         | \$41 | WDTCR      |       | \$36        | \$56  | TWCR    |     |            |         | T         |              |      |
|   | \$0D   | \$2D   | SPCR    |              | \$22                                         | \$42 | ASSR       |       | \$37        | \$57  | SPMCR   |     | 1          |         |           | dress bus    |      |
|   | \$0E   | \$2E   | SPSR    |              | \$23                                         | \$43 | OCR2       |       | \$38        | \$58  | TIFR    |     |            |         |           | and bus      |      |
|   | \$0F   | \$2F   | SPDR    |              | \$24                                         | \$44 | TCNT2      |       | \$39        | \$59  | TIMSK   | ľ   | ta         |         |           |              |      |
|   | \$10   | \$30   | PIND    |              | \$25                                         | \$45 | TCCR2      |       | \$3A        | \$5A  | GIFR    |     | c          |         |           |              |      |
|   | \$11   | \$31   | DDRD    |              | \$26                                         | \$46 | ICR1L      |       | \$3B        | \$5B  | GICR    |     | 3          |         |           | 111          |      |
|   | \$12   | \$32   | PORTD   |              | \$27                                         | \$47 | ICR1H      |       | \$3C        | \$5C  | OCR0    |     |            |         |           |              |      |
|   | \$13   | \$33   | PINC    |              | \$28                                         | \$48 | OCR1BL     |       | \$3D        | \$5D  | SPL     | Ē   |            |         |           |              |      |
|   | \$14   | \$34   | DDRC    |              | \$29                                         | \$49 | OCR1BH     |       | \$3E        | \$5E  | SPH     |     | Inte       | rrupt   | Ports     | Other        | r    |
| L | \$15   | \$35   | PORTC   |              | \$2A                                         | \$4A | OCR1AL     | l i   | \$3E        | \$5E  | SREG    |     | U          | nit     |           | Periphe      | rals |
|   |        |        |         |              |                                              |      |            |       |             |       |         | -   |            |         |           |              |      |
|   | \$001E | Regi   | sters   | <sup>1</sup> |                                              |      |            |       |             |       |         |     |            |         |           |              |      |
|   |        |        |         |              | Exa                                          | mnle | e: Add     | l cor | nten        | Fx:   | amnle   | Sf  | ore        | 0x53 in | to the SE | PH reaister  | -    |
|   | \$0020 |        |         | - H          |                                              |      |            |       |             |       |         | 0   | 010        |         |           | ii i cgistei | · ⊢  |
|   |        | Standa | ard I/O |              | Exa                                          | mple | e: Wha     | at do | oes i       | l The | e addro | ess | s of       | SPH is  | 0x5E      |              |      |
|   |        | Regi   | sters   |              |                                              | •    |            |       |             |       |         |     |            |         |           |              |      |
|   | \$005F |        |         |              | T                                            | DS   | R20.       | 2     |             |       |         |     |            |         |           |              |      |
|   | ¢0060  |        |         |              |                                              |      |            |       |             |       |         |     |            |         |           |              |      |
|   | φ0000  | Gen    | eral    | - 1          |                                              |      |            |       |             | Sc    | olution | •   |            |         |           |              |      |
|   |        | Durn   |         |              | <u>م                                    </u> | ~~~~ | <b>K</b> . |       |             |       | Jacon   | •   |            |         |           |              |      |
|   | :      |        |         |              | An                                           | swe  | Γ.         |       |             |       |         |     |            |         |           |              |      |
|   |        |        |         |              |                                              |      |            |       |             |       | LDI     | R2  | 20,        | 0x53    | ;R2       | 20 = 0x53    |      |
|   |        | (58    | AIVI)   |              | 14                                           | 00n  | ioo th     | ~ ~ ~ | nto         |       |         |     |            |         |           |              |      |
|   |        |        |         |              | IL                                           | cob  | les in     | ecc   | лце         |       | STS     | 03  | 5E         | R20     | : 51      | PH = R20     |      |
|   |        | 1      | ۱<br>ا  |              |                                              |      |            |       |             |       | ~1~     | 01  |            | , 1120  | , 01      |              |      |
|   |        | '      |         |              |                                              |      |            |       |             |       |         |     |            |         |           |              |      |
|   |        |        |         |              |                                              |      |            |       |             |       |         |     |            |         |           |              |      |
|   | \$FFFF |        |         |              |                                              |      |            |       |             |       |         |     |            |         |           |              |      |



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi













### .EQU and .SET

- .EQU name = value
  - Example:

| . EQU | COUNT = 0x25   |             |
|-------|----------------|-------------|
| LDI   | R21, COUNT     | ;R21 = 0x25 |
| LDI   | R22, COUNT + 3 | ;R22 = 0x28 |

- .SET name = value
  - Example:

| . SET | COUNT = 0x25   |             |
|-------|----------------|-------------|
| LDI   | R21, COUNT     | ;R21 = 0x25 |
| LDI   | R22, COUNT + 3 | ;R22 = 0x28 |
| . SET | COUNT = 0x19   |             |
| LDI   | R21, COUNT     | ;R21 = 0x19 |

### .INCLUDE

### • .INCLUDE "filename.ext"

| Table 2-6: | Some of the co | ommon A | AVRs and thei | r include fil | es               |
|------------|----------------|---------|---------------|---------------|------------------|
| MEGA       |                | TINY    |               | Special Pu    | rpose            |
| Mega8      | m8def.inc      | Tiny11  | tn11def.inc   | 90CAN32       | can32def.inc     |
| Mega16     | m16def.inc     | Tiny12  | tn12def.inc   | 90CAN64       | can64def.inc     |
| Mega32     | m32def.inc     | Tiny22  | tn22def.inc   | 90PWM2        | pwm2def.inc      |
| Mega64     | m4def.inc      | Tiny44  | tn44def.inc   | 90PWM3        | pwm3def.inc      |
| Mega128    | m128def.inc    | Tiny85  | tn85def.inc   | 86RF401       | at86rf401def.inc |
| Mega256    | m256def.inc    |         |               |               |                  |
| Mega2560   | m2560def.inc   |         |               |               |                  |

### .INCLUDE

• .INCLUDE "filename.ext"

| Table     | 2-6: Some of th | -6: Some of the common AVRs and their include files |                      |        |  |  |  |  |
|-----------|-----------------|-----------------------------------------------------|----------------------|--------|--|--|--|--|
| MEG       | A               | TINY                                                | Special Purpose      |        |  |  |  |  |
| Mega      | 8 m8def.inc     | Tinv11 tn11c                                        | lefinc 90CAN32 can32 | definc |  |  |  |  |
|           |                 | M32de                                               | ef.inc               |        |  |  |  |  |
| .equ      | SREG            | = 0x3f                                              |                      |        |  |  |  |  |
| .equ      | SPL             | = 0x3d                                              |                      |        |  |  |  |  |
| .equ      | SPH             | = 0x3e                                              |                      |        |  |  |  |  |
| • • • • • |                 |                                                     |                      |        |  |  |  |  |
| .equ      | INT_VEC         | TORS_SIZE =                                         | 42 ; size in wo      | ords   |  |  |  |  |
|           |                 |                                                     |                      |        |  |  |  |  |
|           |                 |                                                     |                      |        |  |  |  |  |

|           | Program.asm  |
|-----------|--------------|
| . INCLUDE | "M32DEF.INC" |
| LDI       | R20, 10      |
| OUT       | SPL, R20     |
|           |              |

#### .ORG

• .ORG address



## Assembler





*AVR Microcontroller and Embedded System Using Assembly and C* Mazidi, Naimi, and Naimi



*AVR Microcontroller and Embedded System Using Assembly and C* Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi

# Fetch and execute



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi
# Pipelining



AVR Microcontroller and Embedded System Using Assembly and C Mazidi, Naimi, and Naimi © 2011 Pearson Higher Education, Upper Saddle River, NJ 07458. • All Rights Reserved.

### How to speed up the CPU

- Increase the clock frequency
  - More frequency → More power consumption & more heat
  - Limitations
- Change the architecture
  - Pipelining
  - RISC

#### Changing the architecture RISC vs. CISC

- CISC (Complex Instruction Set Computer)
  - Put as many instruction as you can into the CPU
- RISC (Reduced Instruction Set Computer)
  - Reduce the number of instructions, and use your facilities in a more proper way.

- Feature 1
  - RISC processors have a fixed instruction size. It makes the task of instruction decoder easier.
    - In AVR the instructions are 2 or 4 bytes.
  - In CISC processors instructions have different lengths
    - E.g. in 8051
      - CLR C ; a 1-byte instruction
      - ADD A, #20H ; a 2-byte instruction
      - LJMP HERE ; a 3-
- ; a 3-byte instruction

- Feature 2: reduce the number of instructions
  - Pros: Reduces the number of used transistors
  - Cons:
    - Can make the assembly programming more difficult
    - Can lead to using more memory

- Feature 3: limit the addressing mode
  - Advantage
    - hardwiring
  - Disadvantage
    - Can make the assembly programming more difficult

• Feature 4: Load/Store



© 2011 Pearson Higher Education, Upper Saddle River, NJ 07458. • All Rights Reserved.

- Feature 5 (Harvard architecture): separate buses for opcodes and operands
  - Advantage: opcodes and operands can go in and out of the CPU together.
  - Disadvantage: leads to more cost in general purpose computers.





© 2011 Pearson Higher Education, Upper Saddle River, NJ 07458. • All Rights Reserved.

 Feature 6: more than 95% of instructions are executed in 1 machine cycle

- Feature 7
  - RISC processors have at least 32 registers.
    Decreases the need for stack and memory usages.
    - In AVR there are 32 general purpose registers (R0 to R31)